package algorithm;

public class leetcode_0044 {
    public static void main(String[] args) {
        System.out.println(isMatch("aa","*"));
    }
    public static boolean isMatch(String s, String p) {
        int lens=s.length();
        int lenp=p.length();
        char[] lists=s.toCharArray();
        char[] listp=p.toCharArray();
        boolean[][] dp=new boolean[lens+1][lenp+1];
        for(int i=0;i<lens+1;++i){
            dp[i][0]=false;
        }
        boolean flag=true;
        for(int j=0;j<lenp+1;++j){
            if(j>0&&listp[j-1]!='*') flag=false;
            if(flag) dp[0][j]=true;
            else dp[0][j]=false;
        }
        for(int i=1;i<lens+1;++i){
            for(int j=1;j<lenp+1;++j){
                if(listp[j-1]=='*'){
                    dp[i][j]=(dp[i-1][j]||dp[i][j-1]);
                }
                else{
                    if(listp[j-1]=='?'){
                        dp[i][j]=dp[i-1][j-1];
                    }
                    else{
                        if(listp[j-1]==lists[i-1]){
                            dp[i][j]=dp[i-1][j-1];
                        }
                        else{
                            dp[i][j]=false;
                        }
                    }
                }
            }
        }
        return dp[lens][lenp];
    }
}
